<template>
  <el-drawer v-model="addDrawer" size="48%" :show-close="false" @opened="openDrawer"
    @close="closeDrawer">
    <template #title>
      <h2><svg-icon icon-class="list"></svg-icon><span style="padding-left: 15px">{{typeName}}</span></h2>
      <el-button type="primary" @click="confirmClick" :disabled="drawerLoading" v-if="isShowSave">保存</el-button>
    </template>
    <template #default>
      <el-form :model="form" ref="addRef" :inline="true" :rules="formRules" label-width="160px" v-loading="drawerLoading">
        <el-row justify="space-between">
          <el-form-item label="省">
            <el-input v-model="form.province" clearable disabled></el-input>
          </el-form-item>
          <el-form-item label="市">
            <el-input v-model="form.city" clearable disabled></el-input>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="区/县">
            <el-input v-model="form.county" clearable disabled></el-input>
          </el-form-item>
          <el-form-item label="断层编号" prop="faultId">
            <el-input v-model="form.faultId" placeholder="请输入断层编号" clearable maxlength="17"></el-input>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="发震时间" prop="occurrenceDate">
            <el-input v-model="form.occurrenceDate" placeholder="请输入发震时间" clearable maxlength="20" />
          </el-form-item>
          <el-form-item label="震中经度" prop="lon">
            <el-input v-model="form.lon" placeholder="请输入震中经度" clearable maxlength="8"></el-input>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="震中纬度" prop="lat">
            <el-input v-model="form.lat" placeholder="请输入震中纬度" clearable maxlength="8"></el-input>
          </el-form-item>
          <el-form-item label="震级" prop="magnitude">
            <el-input v-model="form.magnitude" placeholder="请输入震级" clearable maxlength="8"></el-input>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="断层破裂过程数据文件原始编号" prop="frDataArwid" style="width:100%">
            <el-space direction="vertical" alignment="flex-start" :size="15" class="upload-space">
              <el-input v-model="form.frDataArwid" placeholder="请输入断层破裂过程数据文件原始编号" clearable maxlength="20"></el-input>
              <FileUpload v-model="form.frDataArwidName" @uploadFile="uploadSuccess('frDataArwid', $event)" @delFile="deleteFile('frDataArwid', $event)" />
            </el-space>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="破裂过程反演方法" prop="method" style="width:100%">
            <el-input v-model="form.method" placeholder="请输入破裂过程反演方法" :autosize="{ minRows: 3, maxRows: 6 }"
              type="textarea" show-word-limit maxlength="100" clearable></el-input>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="资料来源" prop="reference" style="width:100%">
            <el-input v-model="form.reference" placeholder="请输入资料来源" :autosize="{ minRows: 4, maxRows: 8 }"
              type="textarea" show-word-limit maxlength="255" clearable></el-input>
          </el-form-item>
        </el-row>
        <el-row justify="space-between">
          <el-form-item label="备注" prop="commentInfo" style="width:100%">
            <el-input v-model="form.commentInfo" placeholder="请输入备注" :autosize="{ minRows: 6, maxRows: 12 }"
              type="textarea" show-word-limit maxlength="2147483647" clearable></el-input>
          </el-form-item>
        </el-row>
      </el-form>
    </template>
  </el-drawer>
</template>
<script setup>
import useSpatialData from '@/hooks/useSpatialData'
import {eightDouble} from '@/utils/validate'
const { route, addDrawer, drawerLoading, form, typeName, openDrawer, closeDrawer, confirmClick, uploadSuccess, deleteFile, isShowSave } = useSpatialData()
const formRules = {
  faultId: [{ required: true, message: '请填写断层编号！', trigger: 'blur' }],
  lon: [ eightDouble],
  lat: [eightDouble],
  magnitude: [ eightDouble]
}
</script>
<style scoped></style>